$(function () {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
    // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)



    // 2.上传头像
    $('#chooseImageBtn').on('click', function () {
        $('#chooseImageIpt').click()
    })


    $('#chooseImageIpt').on('change', function (e) {
        let file = this.files[0]
        if (!file) {
            return layer.msg('请上传图片')
        }
        let newImgURL = URL.createObjectURL(file)
        $image
            .cropper('destroy')      // 销毁旧的裁剪区域
            .attr('src', newImgURL)  // 重新设置图片路径
            .cropper(options)        // 重新初始化裁剪区域
    })


    $('#uploadBtn').on('click', function () {
        var dataURL = $image
            .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
                width: 100,
                height: 100
            })
            .toDataURL('image/png')       // 将 Canvas 画布上的内容，转化为 base64 格式的字符串


            axios({
                method:'POST',
                url:'/my/update/avatar',
                data: 'avatar='+encodeURIComponent(dataURL)
            }).then(res=>{
                if(res.data.status) {
                   return layer.msg(res.data.message)
                }

                layer.msg('恭喜你,头像更换成功')

                window.parent.getUserInfo()
            })
    })
})

